package it.unipd.dei.bd.icineasti.database;

import it.unipd.dei.bd.icineasti.resource.Immagine;

import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * Restituisce la locandina corrispondente al codiceEvento 
 * 
 * @author Morris Antonello
 *
 */
public class GetLocandinaEventoDatabase {

	/**
	 * Interrogazione al database.
	 */
	private static final String STATEMENT = "SELECT Locandina " +
											"FROM Evento " +
											"WHERE Codice = ? ";
	
	/**
	 * Connessione al database
	 */
	private final Connection con;
	
	private final int codiceEvento;
	private Immagine locandina;
	
	public GetLocandinaEventoDatabase(Connection con, int codiceEvento) {
		this.con = con;
		this.codiceEvento = codiceEvento;
	}

	public Immagine getLocandina() throws SQLException {

		PreparedStatement pstmt = null;
		ResultSet rs = null;

		try {
			pstmt = con.prepareStatement(STATEMENT);
			pstmt.setInt(1, codiceEvento);

			rs = pstmt.executeQuery();
			while (rs.next()) {
				locandina = new Immagine("" + codiceEvento, // meglio md5
										 "" + codiceEvento, // meglio md5
										 "image/jpg",
										 rs.getBytes("locandina"));
			}
		} finally {
			if (rs != null) {
				rs.close();
			}

			if (pstmt != null) {
				pstmt.close();
			}

			con.close();
		}
		
		return locandina;
	}
}
